草庐IT

MongoDB 查询列表

全部标签

ruby-on-rails - Rails 列表有 .first 和 .second – 有 .hundredth 或 .sixty_nineth 吗?

Rails是否有类或其他扩展允许系列中的前几个元素(和最后一个)以外的元素?这些工作:[2,45,2,14,53,23,634,346,34,46,643,634,346,34,34].fifth#->53[2,45,2,14,53,23,634,346,34,46,643,634,346,34,34].last#->34那么在哪里呢?list.sixthlist.hundredth 最佳答案 有一段时间Rails添加了这些,但是有很多controversy所以大部分都被删除了。这个实验的唯一残余是Array#forty_two:(

ruby - 如何在 Ruby 中获取 `required` 的文件列表?

这纯粹是一个实验,但我想知道是否有可能通过某种元编程在运行时获取require的gem列表。例如,假设我有:require'rubygems'require'sinatra'require'nokogiri'#don'tknowwhattodohere如何在运行时打印出以下内容?thisappneedsrubygems,sinatra,nokogiri 最佳答案 您不能完全做到这一点,因为需要一个文件可能需要其他文件,而Ruby无法区分您需要的文件和其他人需要的文件。p>您可以查看$LOADED_FEATURES以获取所需的每一项内

sql - 通过关联的 Rails 查询仅限于最近的记录?

classUserhas_many:books我需要一个返回的查询:最近一本书具有:complete=>true的用户。即,如果用户最近的书有:complete=>false,我不希望它们出现在我的结果中。到目前为止我有什么User.joins(:books).merge(Book.where(:complete=>true))这是一个很有希望的开始,但没有给我需要的结果。我试过添加.order("created_ondesc").limit(1)到上述查询的末尾,但是当我期待很多结果时,我最终只得到一个结果。谢谢! 最佳答案 如果

ruby-on-rails - Rails ActiveRecord 查询日期范围

我正在尝试在我的Controller中使用以下行来捕获从当前日期起不到一周的所有任务:@due_this_week=current_user.tasks.where(due_date:Date.today..1.week.from_now)出于某种原因,它没有找到任何结果,即使我知道我有四到六天的任务到期。这是唯一使用范围查询的实例变量。我有另一个可以很好地查找逾期任务的工具:@overdue=current_user.tasks.where("due_date我错过了什么? 最佳答案 应该是:@due_this_week=curr

ruby-on-rails - ActiveRecord 查询中的 “includes” 和 “preload” 有什么区别?

我正在努力寻找ActiveRecord对象的includes()和preload()的比较。谁能解释一下区别? 最佳答案 Rails有两种方法可以避免n+1问题。一个涉及创建一个基于大连接的查询以拉入您的关联,另一个涉及为每个关联进行单独的查询。当您执行includes时,rails会决定为您使用哪种策略。它默认使用单独的查询方法(预加载),除非它认为您正在使用条件或订单中关联的列。因为这只适用于joins方法,所以改用它。Rails的启发式方法有时会出错,或者您可能有特定的原因偏爱一种方法而不是另一种方法。preload(及其配套

ruby - Rails 在最后一个之前加入逗号和 "and"的字符串列表

是否有一个标准的Rails助手可以将字符串数组(如["apple","banana","pear"])转换为"apple,banana,andpear"用于插入句子? 最佳答案 Yeahto_sentence应该工作得很好。http://apidock.com/rails/Array/to_sentence 关于ruby-Rails在最后一个之前加入逗号和"and"的字符串列表,我们在StackOverflow上找到一个类似的问题: https://stack

ruby - 如何在 Ruby 中生成一个包含 n 个唯一随机数的列表?

这是我目前所拥有的:myArray.map!{rand(max)}然而,显然,有时列表中的数字不是唯一的。如何确保我的列表只包含唯一编号,而不必创建一个更大的列表,然后从中选择n个唯一编号?编辑:我真的很想看到这个没有循环的完成——如果可能的话。 最佳答案 (0..50).to_a.sort{rand()-0.5}[0..x](0..50).to_a可以替换成任意数组。0是“最小值”,50是“最大值”x是“我想要多少个值”当然,x不可能被允许大于max-min:)扩展其工作原理(0..5).to_a==>[0,1,2,3,4,5][

ruby-on-rails - Rails 4,使用 ActiveRecord 的原始查询

目前有没有办法在Rails4.0.0.beta1中使用ActiveRecord执行原始SQL选择查询?我看到ActiveRecord::Base.execute不再存在。正确的做法是什么? 最佳答案 在这里试试这个,选择示例..:query="select...."results=ActiveRecord::Base.connection.execute(query) 关于ruby-on-rails-Rails4,使用ActiveRecord的原始查询,我们在StackOverflow上

ruby-on-rails - ActiveRecord - 查询多态关联

我正在使用多态关联来跟踪我项目中的评论。所有非常直接的东西。我遇到的问题是基于多态关联的查询以及从Comment模型连接回它的所有者。所以...我有一个评论模型classCommenttrueend还有一个论坛主题模式:classForumTopic:commentableend我还有其他几个目前不重要的“可评论”模型。所有这些都有效。我想要做的是找到属于具有指定条件(在本例中,'featured'==true)的ForumTopic的所有评论。当我尝试使用取景器加入模型时:@comments=Comment.find(:all:joins=>:commentable:conditio

ruby-on-rails - 在 where 查询中查找 nil has_one 关联

这可能是一个简单的问题,但我似乎正在努力寻找一个优雅的解决方案。我有两个ActiveRecord模型类,它们之间有has_one和belongs_to关联:classItem我正在寻找一种优雅的方法来查找所有Item对象,这些对象没有与之关联的购买对象,理想情况下无需求助于boolis_purchased或Item上的类似属性。现在我有:purchases=Purchase.allItem.where('idnotin(?)',purchases.map(&:item_id))这行得通,但对我来说似乎效率低下,因为它执行两个查询(并且购买可能是一个庞大的记录集)。运行Rails3.1.